

# **Design Digitaler Schaltkreise**

Place and route 1

Asic and Detector Lab - IPE

Prof. Ivan Peric <u>ivan.peric@kit.edu</u> Richard Leys <u>richard.leys@kit.edu</u>





#### **Lecture Goal**



- Get an overview of place and route steps
- Understand floorplaning steps to prepare top level
- After that: Ready to go for final implementation
- Talk about timing later

#### **Place and Route Goal**



- After Synthesis, we have gates and interconnection information
- Physically place the circuit to create an ASIC



### **P&R Strategy**



- Try to create the best conditions for an easy implementation
- Ex: Not too big (long wires), Not too small (less optimisation freedom)
- But take into account the design constraints, like embedded special blocks (PLL, Memories, Test controllers), cost etc
- Let the software perform as much automated work as possible
- Timing is checked the whole time
  - Each step have small adjustment steps to improve timing

#### **Floorplaning Overview**



- Prepare the design for physical implementation: set the foundations
- The best the floorplaning, the less effort required by automated tasks
- Usually heavily scripted because a lot of small components must be added to the design for physical rules
  - If any re-synthesis is necessary, just re-run the script

#### During floorplaning:

- Prepare the die dimensions
- Prepare the I/O
- Pre-Place hard macros
- Route special wires
- Create Partitions (if necessary)
- Add spare cells, well tap etc...
- Ready to continue!

#### **6** 23.06.2016

#### Asic and Detector Lab - IPE

I/O Bound

# Die Size Configuration

- Core Die Area
- Size constraint:
  - Cost
  - Technical limitation (Multi layer Mask)
  - Minimal size sometimes
- Size Definition:
  - I/O bound: Too many pins

Core Area Bound

Core bound: Too much logic









#### **I/O Placement and Pads**



- I/O provide interface to external world
- In smaller technology node, there is an IO voltage:
  - UMC65: 1.8 V for IO typically, ~1V for core logic
- I/O cells are big and provide voltage translation, as well as ESD protection
- Like Standard cells, they are designed to be abutted to each other



7

### **Power Domains and IO**



- Power Domains are used to separate various supplies:
  - Typical: Analog and Digital Domains
  - Possible: Multiple digital power domains
- Explanation:
  - Digital and Analog are separated to avoid power supply cross-talk
  - A digital domain can have a lower VDD to save power, and another one a higher VDD for better performances
- Advanced options:
  - Digital Power domains can interface using level shifters placed by the tool
  - Digital Power domain can be "shutdown"; like a sleep mode

| <b>P1.0</b><br>(A1)  |                     | <b>K PJ.5</b>         | <b>P7.3</b>         | <b>PJ.3</b>         | <b>PJ.2</b> | <b>P6.5</b>         | <b>P6.4</b>         | <b>P6.2</b>         |
|----------------------|---------------------|-----------------------|---------------------|---------------------|-------------|---------------------|---------------------|---------------------|
| <b>P1.1</b> (B1)     | SWDIOTM             | s <b>PJ.4</b><br>(B3) | <b>P7.2</b>         | <b>P7.0</b>         | RSTn/NM     | <b>P6.7</b>         | <b>P6.6</b>         | <b>P6.3</b>         |
| <b>P1.5</b><br>(C1)  |                     |                       | <b>P1.2</b>         | <b>P7.1</b><br>(C5) | DVCC2       | DVSS3               | <b>P5.5</b>         | <b>P5.7</b>         |
| <b>P1.6</b><br>(D1)  | DVCC1               | <b>P1.4</b>           | <b>P1.3</b>         | AVCC2               | AVSS2       | <b>P5.3</b>         | <b>P5.4</b><br>(D8) | <b>P5.6</b><br>(D9) |
| <b>P1.7</b>          | VSW<br>(E2)         | <b>P2.2</b><br>(E3)   | <b>P2.0</b><br>(E4) | AVSS3               | DVSS2       | <b>P5.0</b>         | <b>P5.1</b><br>(E8) | <b>P5.2</b><br>(E9) |
| <b>P2.1</b><br>(F1)  | DVSS1               | <b>P2.4</b>           | <b>P2.3</b>         | AVSS1               | AVCC1       | <b>P4.5</b><br>(F7) | <b>P4.6</b><br>(F8) | <b>P4.7</b><br>(F9) |
| <b>P2.5</b>          | <b>P2.6</b>         | <b>P7.7</b>           | <b>P8.1</b><br>(G4) | <b>P3.2</b>         | <b>P3.5</b> | <b>P4.2</b>         | <b>P4.3</b>         | <b>P4.4</b>         |
| <b>P2.7</b>          | <b>P7.5</b>         | <b>P8.0</b>           | <b>P3.1</b>         | <b>P3.4</b>         | <b>P3.7</b> | <b>P6.1</b>         | <b>P4.1</b>         | <b>P4.0</b>         |
| <b>P7.4</b><br>( J1) | <b>P7.6</b><br>(J2) | <b>P3.0</b><br>(J3)   | <b>P3.3</b>         | <b>P3.6</b>         | <b>PJ.0</b> | <b>PJ.1</b><br>(J7) | <b>DCOR</b><br>(J8) | <b>P6.0</b>         |

#### TI MSP432 Microcontroller PADS

### **IO Power rows design**



- IO Cells have specific rules for power rail connections
- The Technology documentation provide information
- Design by abutment, power rails must respect some rules:
- All power domains must be separated



Figure 4-3-A. An Example of a Digital-to-Digital Interface

Example from UMC65: Multiple Digital Domains

#### **IO Placement types**





Area I/O

#### **PAD type: Wire Bonding Pads**



Connection PADS can be around the core, with AREA IO or not



# **PAD type: AREA IO for Flip-Chip**



- Area IO and Bumps are used for Flip-Chip mounting
- Bump to IO Cell is routed over a Redistribution Thich Metal layer







DCD





# **IO Cell Types**



- IO Cells can be of various types, depending on the technology library
- Standard types:
  - Power Connections: VDD,VSS,VDDIO,VSSIO
  - Fillers: FILLER1, FILLER10, CORNER
  - Signal Cell for Digital/Analog Signals
- Special Cells:
  - Differential Signal (ex: LVDS), Oscillator cells etc...





Special Cells example: Oscillator

# Partitioning: Definition and re-implementation



- Partitions are used to cut-off the design in smaller subset
- Each Subset is synthesised and implemented separately.
- The top level prepares IO Placement between partitions
- Final timing is done at top level with last adjustments



#### **Partition Level implementation**



- Like top level but constraints and IO are provided
- Proceed to normal implementation
- Leave topmost layers in technology for top level connections



Partition Layers strategy example



Partition Base Design

#### **Hard Macros**

- Hard Macros are like partitions, but ready to use
- LEF file provides size and IO information
- Most common cases:
  - SRAMS
  - PLL
  - Temperature sensor
- Place objects as any other



Sometimes design have many rams



### **Pre-Placement : Finish floorplan**



- Cut the Rows to leave space around the hard macros
- Add specifics like Well-Taps: See Technology documentation



#### **Pre-Placement: WellTap example**



- Latchup: VDD/GND short due to parasitic BJT
- Prevent Latchup: Require enough Well contacts to keep Rsub low
- See Technology documentation
- Links to read:
- http://www.analog.com/library/analogDialogue/archives/35-05/latchup/index.html
- http://www.ece.drexel.edu/courses/ECE-E431/latch-up/latch-up.html



#### **Pre-Placement: Spare Cells example**



- Some clusters of cells can be added on the core area for latter fixes.
- The production masks can be slightly modified to fix an issue. The spare cells can be used to modify the logic a bit.



#### **Placement in the Tools**



- How does placement happen in the tools?
- Simply programming:
  - Find the object in the design hierarchy if they were synthesised
    - find /path/to/object
  - Manually Create Instances for special cells
  - Place with coordinates
    - placeInstance 100 200 \$ram
- The tools sometimes have special commands to place extra structures:
  - Typically: Fillers
- Remember: This is just software, placement could be prepared anywhere and a script generated, or a DEF file generated etc...

#### **Power planning and Power Analysis**



- Power domains:
  - Analog and digital
  - Multiple Digital power domains are possible as well
- Power connections are important
  - If not enough of them the voltage drop across the design can be huge: IR drop picture
- Problem: Functional Power analysis are not simple, runtimes are long
- Solution: Add as much as you can





IR Drop example

Source: semiwiki.com

#### **Power Grid: Global Grid**



Use the addStripe command to add power stripes on high metal layers



### **Power Grid: Rows and Macros connections**



- Use the editPowerVia command to add VIA down to the power pins of the standard rows and macros.
- Consult the technology files (like LEF) to find out on which layer the power pins are available



#### **Standard Cells Placement**



- Quite trivial, automatically place the cells where can be
  - -> placeDesign in tool
- Tries to optimize timing
- Floorplaning drives the placements
  - I/O
  - Hard macro

#### **Placement constraints**



- Standard cells can be constraints to regions and fences
- Relates to FPGA floorplaning as well (box in Xilinx ISE)
- Usually not needed, sometimes useful





#### Next time

- Timing Configuration
- Clock tree synthesis
- Routing
- Timing Fixes along the design flow



#### End Slide